home *** CD-ROM | disk | FTP | other *** search
/ Amiga Plus Leser 19 / Amiga Plus Leser CD 19.iso / Tools / MorphOS / cvs-1.11.2 / source / amiga / netinclude / net / if_arp.h < prev    next >
Encoding:
C/C++ Source or Header  |  2002-11-18  |  3.9 KB  |  99 lines

  1. /*
  2.  * Copyright (c) 1986, 1993
  3.  *    The Regents of the University of California.  All rights reserved.
  4.  *
  5.  * Redistribution and use in source and binary forms, with or without
  6.  * modification, are permitted provided that the following conditions
  7.  * are met:
  8.  * 1. Redistributions of source code must retain the above copyright
  9.  *    notice, this list of conditions and the following disclaimer.
  10.  * 2. Redistributions in binary form must reproduce the above copyright
  11.  *    notice, this list of conditions and the following disclaimer in the
  12.  *    documentation and/or other materials provided with the distribution.
  13.  * 3. All advertising materials mentioning features or use of this software
  14.  *    must display the following acknowledgement:
  15.  *    This product includes software developed by the University of
  16.  *    California, Berkeley and its contributors.
  17.  * 4. Neither the name of the University nor the names of its contributors
  18.  *    may be used to endorse or promote products derived from this software
  19.  *    without specific prior written permission.
  20.  *
  21.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  22.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  23.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  24.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  25.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  26.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  27.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  28.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  29.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  30.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  31.  * SUCH DAMAGE.
  32.  *
  33.  *    @(#)if_arp.h    8.1 (Berkeley) 6/10/93
  34.  */
  35.  
  36. #ifndef _NET_IF_ARP_H
  37. #define _NET_IF_ARP_H
  38.  
  39. #ifndef EXEC_TYPES_H
  40. #include <exec/types.h>
  41. #endif /* EXEC_TYPES_H */
  42.  
  43. #ifndef _SYS_SOCKET_H
  44. #include <sys/socket.h>
  45. #endif /* _SYS_SOCKET_H */
  46.  
  47. /*
  48.  * Address Resolution Protocol.
  49.  *
  50.  * See RFC 826 for protocol description.  ARP packets are variable
  51.  * in size; the arphdr structure defines the fixed-length portion.
  52.  * Protocol type values are the same as those for 10 Mb/s Ethernet.
  53.  * It is followed by the variable-sized fields ar_sha, arp_spa,
  54.  * arp_tha and arp_tpa in that order, according to the lengths
  55.  * specified.  Field names used correspond to RFC 826.
  56.  */
  57. struct    arphdr {
  58.     UWORD    ar_hrd;        /* format of hardware address */
  59. #define ARPHRD_ETHER     1    /* ethernet hardware format */
  60. #define ARPHRD_FRELAY     15    /* frame relay hardware format */
  61.     UWORD    ar_pro;        /* format of protocol address */
  62.     UBYTE    ar_hln;        /* length of hardware address */
  63.     UBYTE    ar_pln;        /* length of protocol address */
  64.     UWORD    ar_op;        /* one of: */
  65. #define    ARPOP_REQUEST    1    /* request to resolve address */
  66. #define    ARPOP_REPLY    2    /* response to previous request */
  67. #define    ARPOP_REVREQUEST 3    /* request protocol address given hardware */
  68. #define    ARPOP_REVREPLY    4    /* response giving protocol address */
  69. #define ARPOP_INVREQUEST 8     /* request to identify peer */
  70. #define ARPOP_INVREPLY    9    /* response identifying peer */
  71. /*
  72.  * The remaining fields are variable in size,
  73.  * according to the sizes above.
  74.  */
  75. #ifdef COMMENT_ONLY
  76.     UBYTE    ar_sha[];    /* sender hardware address */
  77.     UBYTE    ar_spa[];    /* sender protocol address */
  78.     UBYTE    ar_tha[];    /* target hardware address */
  79.     UBYTE    ar_tpa[];    /* target protocol address */
  80. #endif
  81. };
  82.  
  83. /*
  84.  * ARP ioctl request
  85.  */
  86. struct arpreq {
  87.     struct    sockaddr arp_pa;        /* protocol address */
  88.     struct    sockaddr arp_ha;        /* hardware address */
  89.     LONG    arp_flags;            /* flags */
  90. };
  91. /*  arp_flags and at_flags field values */
  92. #define    ATF_INUSE    0x01    /* entry in use */
  93. #define ATF_COM        0x02    /* completed entry (enaddr valid) */
  94. #define    ATF_PERM    0x04    /* permanent entry */
  95. #define    ATF_PUBL    0x08    /* publish entry (respond for other host) */
  96. #define    ATF_USETRAILERS    0x10    /* has requested trailers */
  97.  
  98. #endif /* _NET_IF_ARP_H */
  99.